package com.sheng.leetcode.year2023.month12.day29;

import org.junit.Test;

import java.util.Arrays;

/**
 * @author by ls
 * @date 2023/12/29
 * <p>
 * 2706. 购买两块巧克力<p>
 * <p>
 * 给你一个整数数组 prices ，它表示一个商店里若干巧克力的价格。同时给你一个整数 money ，表示你一开始拥有的钱数。<p>
 * 你必须购买 恰好 两块巧克力，而且剩余的钱数必须是 非负数 。同时你想最小化购买两块巧克力的总花费。<p>
 * 请你返回在购买两块巧克力后，最多能剩下多少钱。<p>
 * 如果购买任意两块巧克力都超过了你拥有的钱，请你返回 money 。注意剩余钱数必须是非负数。<p>
 * <p>
 * 示例 1：<p>
 * 输入：prices = [1,2,2], money = 3<p>
 * 输出：0<p>
 * 解释：分别购买价格为 1 和 2 的巧克力。你剩下 3 - 3 = 0 块钱。所以我们返回 0 。<p>
 * <p>
 * 示例 2：<p>
 * 输入：prices = [3,2,3], money = 3<p>
 * 输出：3<p>
 * 解释：购买任意 2 块巧克力都会超过你拥有的钱数，所以我们返回 3 。<p>
 * <p>
 * 提示：<p>
 * 2 <= prices.length <= 50<p>
 * 1 <= prices[i] <= 100<p>
 * 1 <= money <= 100<p>
 */
public class LeetCode2706 {

    @Test
    public void test01() {
        int[] prices = {1, 2, 2};
        int money = 3;
//        int[] prices = {3, 2, 3};
//        int money = 3;
        System.out.println(new Solution().buyChoco(prices, money));
    }
}

class Solution {
    public int buyChoco(int[] prices, int money) {
        Arrays.sort(prices);
        int sum = prices[0] + prices[1];
        return money - sum >= 0 ? money - sum : money;
    }
}
